

# STEPS TO CONFIGURE MICROCONTROLLER PINS AS GPIO

ARM Cortex-M4 Microcontroller



### ARM Cortex-M4 Microcontroller

Following are the basics steps required to configure microcontroller pin as GPIO:

- Step 1: Clock Configuration
- Step 2: GPIO Port Bus Selection
- Step 3: Mode Control Configuration
- Step 4: Pad Control Configuration
- Step 5: Data Control Configuration

### ARM Cortex-M4 Microcontroller

### Step 1: Clock Enable

Step 2: GPIO Bus Selection

Step 3: Mode Control Config.

Step 4: Pad Control Config.

- Enable clock for GPIO Port whether entire port or few pins are to be configured as GPIO
- RCGC\_GPIO\_R register, mapped to memory address 0x400FE608, is used enable clock for GPIO
- Bit 0 to 5 of RCGC\_GPIO\_R can be set to enable clock to PortA to PortF, respectively
  - e.g., 0010 0000 = 0x20 value written on RCGC\_GPIO\_R will enable clock to GPIO PortF
  - e.g., 0000 1001 = 0x09 value written on RCGC\_GPIO\_R will enable clock to GPIO PortA and PortD
- After enabling the clock to a GPIO module, there must be a 3clock cycle delay before accessing the GPIO registers

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

### Step 2: GPIO Bus Selection

Step 3: Mode Control Config.

Step 4: Pad Control Config.

- GPIO module or GPIO port registers can be accessed using two different buses. One of them is the legacy bus called Advanced Peripheral Bus (APB), while the other bus is the Advanced High-Performance Bus (AHB).
- All the registers associated with each port are accessible from both the buses, but they are mapped to different address spaces in the peripheral address space.
- For example, the registers associated with PortF on TM4C123 microcontroller are accessible from APB bus using the address space 0x40025000-0x40025FFF or they can be accessed from AHB bus using the address space 0x4005D000-0x4005DFFF.

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

### Step 2: GPIO Bus Selection

Step 3: Mode Control Config.

Step 4: Pad Control Config.

- Bus configuration is selected (either **APB** or **AHB**) by selecting appropriate base address of the GPIO Port
  - e.g., 0x40025000 is the base address for PortF Registers APB bus

| Base Address | Description                   |  |  |
|--------------|-------------------------------|--|--|
| 0x4000 4000  | GPIO Port A Registers APB Bus |  |  |
| 0x4000 5000  | GPIO Port B Registers APB Bus |  |  |
| 0x4000 6000  | GPIO Port C Registers APB Bus |  |  |
| 0x4000 7000  | GPIO Port D Registers APB Bus |  |  |
| 0x4002 4000  | GPIO Port E Registers APB Bus |  |  |
| 0x4002 5000  | GPIO Port F Registers APB Bus |  |  |
| 0x4005 8000  | GPIO Port A Registers AHP Bus |  |  |
| 0x4005 9000  | GPIO Port B Registers AHP Bus |  |  |
| 0x4005 A000  | GPIO Port C Registers AHP Bus |  |  |
| 0x4005 B000  | GPIO Port D Registers AHP Bus |  |  |
| 0x4005 C000  | GPIO Port E Registers AHP Bus |  |  |
| 0x4005 D000  | GPIO Port F Registers AHP Bus |  |  |

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

### Step 3: Mode Control Config.

Step 4: Pad Control Config.

- GPIO Port pins can be configured for alternate functionalities e.g., PWM, ADC, SPI etc.
- When an alternate functionality is configured, port pins cannot be used as GPIO
- GPIO Alternate Function Select Register (GPIO\_AFSEL\_R, Offset value 0x420) is used for configuring alternate functionality
- This register must be cleared to use GPIO functionality
- e.g., to disable alternate functionality on all the pins of GPIO **PortA** (base address: 0x40004000), we will write 0x00 on register 0x40004420 (= 0x40004000 + 0x420)

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

### Step 3: Mode Control Config.

Step 4: Pad Control Config.

- To configure a specific alternate functionality, the GPIO Port Control (GPIO\_PCTL\_R) register is used, which selects one of several available peripheral functions multiplexed for the specific microcontroller pin.
- It is also possible to use some of the pins for analog input functionality. When a port pin is to be used as an analog to digital converter (ADC) input, the appropriate bit in the GPIO Analog Mode Select (GPIO\_AMSEL\_R) register must be set to disable the analog isolation circuit.

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

**Step 3: Mode Control Config.** 

### Step 4: Pad Control Config.

- Multiple Pad Control registers are required to configure
  - Digital Enable: GPIO\_DEN\_R (Offset Value: 0x51C)
  - Pull Up Configuration: GPIO\_PU\_R (Offset Value: 0x510)
  - Pull Down Configuration: GPIO\_PD\_R (Offset Value: 0x514)
  - Slew Rate Configuration: GPIO\_SL\_R (Offset Value: 0x518)
- Each GPIO Pin can be individually configured using these Pad Control registers
- To use a pin as GPIO, the corresponding bit in GPIO\_DEN\_R
  must be set
- e.g. if we want to enable pin 3 and 4 of GPIO **PortF** (base address: 0x40025000), we will write 0x18 (0001 1000) on register **GPIO\_DEN\_R** 0x4002551C (= 0x40025000 + 0x51C)

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

**Step 3: Mode Control Config.** 

**Step 4: Pad Control Config.** 

Step 5: Data Control Config.

### PIN DIRECTION CONTROL

- Each individual port pin can be configured as an Input or Output using register GPIO\_DIR\_R (Offset Value: 0x400)
- Clearing a register bit configures corresponding port pin as an Input and setting a register bit configures corresponding port pin as an Output
- e.g. if we want to configure GPIO PortF (base address: 0x40025000) pin 3 as output and 4 as input, we will write 0x08 (0000 1000) on register GPIO\_DIR\_R 0x40025400 (= 0x40025000 + 0x400)

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

**Step 3: Mode Control Config.** 

**Step 4: Pad Control Config.** 

Step 5: Data Control Config.

### **GPIO MASKING**

- GPIO\_DATA\_R (Offset Value: 0x000-0x3FC) is used to read/write data from/to GPIO pins
- When configured as input, the value of GPIO pin is captured and stored in corresponding bit of GPIO\_DATA\_R register
- When configured as output, the corresponding
   GPIO\_DATA\_R register bit value is drive the GPIO port pin
- Some port pins can be configured as input while others as output and GPIO\_DATA\_R can be used to read (input data) and write (output data) operations

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

**Step 3: Mode Control Config.** 

**Step 4: Pad Control Config.** 

Step 5: Data Control Config.

### **GPIO MASKING**

- In a single instruction cycle, read or write operation for individual (or multiple) GPIO port pins can be performed without affecting others
- Bit 2 to 9 can be used to construct the mask and corresponding 12-bit value is used as Offset value
- e.g. if we want to access only pin 1 of GPIO PortF (base address: 0x40025000) then 0x008 (0000 0000 1000) will be the Offset value and we will perform operation on GPIO\_DATA\_R located at 0x40025000 (= 0x40025008 + 0x008)

### ARM Cortex-M4 Microcontroller

**Step 1: Clock Enable** 

**Step 2: GPIO Bus Selection** 

**Step 3: Mode Control Config.** 

**Step 4: Pad Control Config.** 

| Offset Address | Offset Address Bits | Accessible Bits                |  |
|----------------|---------------------|--------------------------------|--|
| 0x000          | 0000 0000 0000      | No bit accessible              |  |
| 0x004          | 0000 0000 0100      | Bit 0 is accessible            |  |
| 0x008          | 0000 0000 1000      | Bit 1 is accessible            |  |
| 0x00C          | 0000 0000 1100      | Bit 0 and 1 are accessible     |  |
| 0x010          | 0000 0001 0000      | Bit 2 is accessible            |  |
| 0x01C          | 0000 0001 1100      | Bit 0, 1, and 2 are accessible |  |
| 0x020          | 0000 0010 0000      | Bit 3 is accessible            |  |
| 0x030          | 0000 0011 0000      | Bit 2 and 3 are accessible     |  |
| 0x038          | 0000 0011 1000      | Bit 1, 2, and 3 are accessible |  |
| •••            | •••                 |                                |  |
| 0x3F8          | 0011 1111 1000      | Bit 1 to 7 are accessible      |  |
| 0x3FC          | 0011 1111 1100      | Bit 0 to 7 are accessible      |  |

### TIVA C Series LaunchPad

Program to blink TIVA C Series LaunchPad On-board Green LED to blink at 2 Hz

| Step                 | Configuration             | Register<br>Involved | Register Address |  |
|----------------------|---------------------------|----------------------|------------------|--|
| 1                    | Clock Enable              | RCGC_GPIO_R          |                  |  |
| 2                    | <b>GPIO</b> Bus Selection | GPIO PortF           |                  |  |
| 3                    | Mode Control Config.      | GPIO_AFSEL_R         |                  |  |
| 4                    | Pad Control Config.       | GPIO_DEN_R           |                  |  |
| 5 Data Control Confi |                           | GPIO_DIR_R           |                  |  |
|                      | Data Control Config.      | GPIO_DATA_R          |                  |  |

# THANK YOU

Any Questions???